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DETAILED ACTION 

1 . Claims 1-24 are pending in the current application. 

Response to Arguments 

2. Applicant's arguments filed 09/12/2006 have been fully considered but they are 
not persuasive. 

In response to the Non-Final Office Action dated 07/13/2006, applicant argues 
that Abjanic does not disclose or suggest a process map comprising script messages, 
each message specifying an associated node, a list of the parameters the node 
requires, and values which it returns for a type of incoming message. 

Examiner respectfully disagrees and submits that Abjanic teaches the process 
map comprising script messages [XML pattern; col. 7. lines 5 - 33] each message of 
the process map specifies an associated node [configuration patterns; col. 7, lines 5 - 
33], a list of the parameters the node requires [configuration pattern may require 
multiple patterns, or even a hierarchical arrangement of data elements in the application 
data for a specific match; col. 9, lines 10 - 35], and values which it returns for a type of 
incoming message [Broker 410 also translates destination addresses for return 
messages or replies from the processing node or server sent to the client; coL 10, lines 
55 - 67 and col. 1 1 . lines 1 - 33]. Abjanic discloses pattern requirements and 
arrangement of data elements in the application data for each specific server. 
Therefore, the pattern requirements in Abjanic meet the recited parameters required for 
each node. Finally, the broker knows which value is return for a type of incoming 
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message because the broker maps destination addresses for return messages or 
replies from the processing node or server sent to the client. Therefore, the 
combination of Mehra and Abjanic teaches applicant's invention as claimed. 

Allowable Subject Matter 

3. Claim 19 is allowed. 

4. Claims 13 and 22 are objected to as being dependent upon a rejected base 
claim, but would be allowable if rewritten in independent form including all of the 
limitations of the base claim and any intervening claims. 

Claim Rejections - 35 USC § 103 

5. The following is a quotation of 35 U.S.C. 103(a) which forms the basis for all 
obviousness rejections set forth in this Office action: 

(a) A patent may not be obtained though the invention is not identically disclosed or described as set 
forth in section 102 of this title, if the differences between the subject matter sought to be patented and 
the prior art are such that the subject matter as a whole would have been obvious at the time the 
invention was made to a person having ordinary skill in the art to which said subject matter pertains. 
Patentability shall not be negatived by the manner in which the invention was made. 

6. This application currently names joint inventors. In considering patentability of 
the claims under 35 U.S.C. 103(a), the examiner presumes that the subject matter of 
the various claims was commonly owned at the time any inventions covered therein 
were made absent any evidence to the contrary. Applicant is advised of the obligation 
under 37 CFR 1 .56 to point out the inventor and invention dates of each claim that was 
not commonly owned at the time a later invention was made in order for the examiner to 



Application/Control Number: 09/741 ,860 Page 4 

Art Unit: 2194 

consider the applicability of 35 U.S.C. 103(c) and potential 35 U.S.C. 102(e). (f) or (g) 
prior art under 35 U.S.C. 103(a). 

7. Claims 1 - 4, 6 - 12, 15 - 18, 20, 21, 23 and 24 are rejected under 35 U.S.C. 
103(a) as being unpatentable over "Designing a flexible services-based 
architecture for Internet Applications" [hereinafter Mehra] in view of U.S. Patent 
No. 6,732,175 to Abjanic, both references cited in the previous office action. 

8. As to claim 1 , Mehra teaches the invention substantially as claimed including an 
interface for interfacing between front-end data processing systems and back-end data 
processing systems [p. 31, figure in section 3, Client Layer and Database/Existing 
Applications], the interface comprising an engine [p. 31, figure in section 3. Context 
Processor], a node layer comprising at least one node [p. 31 , figure in section 3, 
Business Logic Layer], and a utility layer comprising at least one utility [p. 31 , figure in 
section 3, Interface], and in which: 

the engine configured to receive a message containing a request from a front- 
end system for a transaction to be perfonned by a back-end system [p. 32, section 
3.2.1], 

each node represents business logic interfaces to a back-end system [p. 32, 
section 3.3.1], 

each node exposes business logic capabilities to the engine [p. 32, the interface 
of the Business Controller Object, section 3.3.2]; 
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each utility is cxDupled as a proxy to a back-end system, and is configured to for 
receiving a transaction request from a node, for converting said request to a back-end 
system request, for receiving a response from the back-end system, and for routing a 
response to the requesting node [p. 32, sections 3.4.1 and 3.4.2], 

each node routes a received response to the engine [p. 32, section 3.2.1 "The 
business logic layer... returns an XML output data stream"]; and 

the engine routes a response to the requesting front-end system [p. 32. section 
3.2.1 "The style sheet rendering engine merges the XML data stream with the 
appropriate XSL template file to render HTML output to the browser."]. 
9. Although. Mehra teaches the invention substantially, Mehra does not specifically 
disclose the engines comprising means for interpreting the message to select a relevant 
node from a plurality of nodes for interfacing, wherein the engine does not contain any 
business logic and the message not containing an operation identifier of the transaction 
to be performed. 

However, Abjanic teaches interfacing between front-end data processing 
systems [clients, for example, may include a server 110 that includes an application 
program 1 12, a computer 120 (such as a personal computer or laptop) that may include 
a web browser 122 and a wireless device 132, such as a personal digital assistant 
(PDA) or a wireless (or cellular) telephone; col. 3, lines 47 - 65] and back-end data 
processing systems [data center 135 includes several processing nodes (e.g., servers), 
including server 150, server 160 and server 170 for handling the various orders, 
business transactions and other requests; col. 3, line 65 - col. 4, line 12], an engine 
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configured to receive a message containing a request from a front-end system for a 
transaction to be performed by a back-end system [content based message director (or 
XML director) can receive and switch messages based upon application data or 
business transaction information regardless of the transport or protocol used to 
transport the message; coL 3, lines 38 - 47; col. 4, lines 50 - 60], and means for 
interpreting said message to select a relevant node from a plurality of nodes for 
interfacing [application data or XML data (including markup characters and/or character 
data) is then compared to one or more configuration patterns or queries (which may be 
stored in the director 145) to determine if there is a match; col. 6, lines 50 - 63] the 
message not containing an operation identifier of the transaction to be performed [a 
match is found between the business transaction information and the pattern, the 
content based switching logic 316 outputs a switching decision to a output interface 
320. The switching decision may, for example, indicate that a match was found and 
identify the processing node or server; col. 9, lines 29 - 35 and col. 3. lines 14-23] 
wherein the engine does not contain any business logic [message director 145 to direct 
or switch messages to a selected server based upon the content of application data, 
such as business transaction information, col. 4, lines 50 - 60; examiner notes that the 
message director sends messages to the server or processing node to process the 
message, col. 3, lines 10-22, therefore, the message director does not contain any 
business logic], each node represents business logic interfaces to a back-end system, 
each node exposes business logic capabilities to the engine [different types of services 



Application/Control Number: 09/741 .860 Page 7 

Art Unit: 2194 

(or different levels of service) to be provided for messages based on the content of the 
application data; col. 7, lines 33 - 43]; 

the engine comprises means for using the exposed node business logic 
capabilities to automatically build [configuration patterns may be dynamically changed 
or updated by a user or by a program or application. For example, a program may 
detect the failure of one or more servers and/or detect the response time of servers, and 
then update the configuration pattern to account for these changes in the network; col. 

6, lines 50 - 63] a process map [configuration pattern; col. 7. lines 6 - 33] linking 
received request messages with nodes, wherein the engine uses the process map to 
select the relevant node from the plurality of nodes [Based on the above configuration 
patterns, the director 145 would direct a message to server; col. 7, lines 23 - 33], the 
process map comprising script messages [XML pattern; col. 7. lines 5 - 33] each 
message of the process map specifies an associated node [configuration patterns; col. 

7. lines 5 - 33]. a list of the parameters the node requires [configuration pattern may 
require multiple patterns, or even a hierarchical arrangement of data elements in the 
application data for a specific match; col. 9. lines 10 - 35]. and values which it returns 
for a type of incoming message [Broker 410 also translates destination addresses for 
return messages or replies from the processing node or server sent to the client; col. 10, 
lines 55 - 67 and col. 1 1 , lines 1 - 33]; and 

each utility is coupled as a proxy to a back-end system, and is configured to for 
receiving a transaction request from a node, for converting said request to a back-end 
system request, for receiving a response from the back-end system, and for routing a 
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response to the requesting node [Broker 410 performs address translation on the 
header(s) for the message; col. 10. lines 33 - 67]. 

It would have been obvious to a person of ordinary skill in the art at the time of 
the invention to apply the teaching of interpreting the message to select a relevant node 
from a plurality of nodes for interfacing, wherein the engine does not contain any 
business logic and the message not containing an operation identifier of the transaction 
to be performed as taught by Abjanic to the invention of Mehra because this offloads the 
burden of examining the application data or business transaction information and then 
switching to a particular processing node from application servers [col. 3, lines 33 - 39 
of Abjanic]. 

8. As to claim 2 Mehra as modified teaches the engine comprises means for 
dynamically maintains the process map according to the exposed node business logic 
capabilities [col. 6, lines 50 - 63 of Abjanic]. 

9. As to claim 3, Mehra teaches the process map comprises a script file [XML is 
used for structured data message; Section 2, p. 31]. 

10. As to claim 4, Mehra as modified teaches each message having a map 
associating incoming parameter names with standardised names [col. 7, lines 23 - 33 
of Abjanic]. 
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11. As to claim 6, Mehra teaches that the utilities interface with the node layer 
according to a uniform interface model ["...that provide an abstraction layer that 
encapsulates access..."; section 3.3.2, p. 32]. 

1 2. As to claim 7, Mehra as modified teaches the engine calls a plurality of nodes for 
a transaction request [col. 7. lines 2-6 of Abjanic]. 

13. As to claim 8, Mehra as modified teaches the engine is configured for calling 
nodes in sequence, and for passing the output from a previous node to a next node [col. 
9, lines 50 - 55 of Abjanic]. 

14. As to claim 9, Mehra as modified teaches the engine and each node uses a 
hashtable mapping keys to values for passing data and control to each other [col. 10, 
lines 33 - 67 of Abjanic]. 

15. As to claims 10 and 1 1 , Mehra as modified teaches the engine and the nodes 
each use a hashtable for returning a result from a back-end system [col. 10, lines 33 - 
67 of Abjanic]. 

16. As to claim 12, Mehra teaches each of the engine and each node comprise an 
object instantiated from an object-oriented class [section 3.3.2. p. 32]. 
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17. As to claim 15, Mehra as modified teaches the engine comprises an externally 
visible engine class ["Servlet"; section 3.2.2 "Servlet" of Mehra], an object of which 
comprises means for instantiating: a processor object for instantiating said node objects 
["Business Object Factory"; section 3.3.1, p. 31 of Mehra]; and a loader object for 
loading the process map, and for determining node objects associated with a received 
message [col. 6, lines 50 - 63 of Abjanic]. 

18. As to claim 16, Mehra as modified teaches the engine is configured for 
instantiating a parser object for parsing a received message [parses all or part of the 
application data; col. 6, lines 39 - 49 of Abjanic], for placing extracted data in a 
hashtable. and for returning the hashtable to the engine object [col. 10, lines 33 - 67 of 
Abjanic]. 

19. As to claim 17, Mehra as modified teaches the engine comprises a builder object 
configured for automatically updating the process map according to capabilities 
exposed by node classes [col. 6, lines 50 - 63 of Abjanic]. 

20. As to claim 18, Mehra as modified teaches each node class comprises a method 
for returning a string to the engine indicating the node capabilities [program may detect 
the failure of one or more servers and/or detect the response time of servers, and then 
update the configuration pattern to account for these changes in the network; col. 6. 
lines 56 - 63 of Abjanic]. 



Application/Control Number: 09/741,860 



Art Unit: 2194 



Page 1 1 



21 . As to claim 20, Mehra as modified teaches a metfiod of interfacing between front- 
end data processing systems and back-end data processing systems [p. 31. figure in 
section 3. Client Layer and Database/Existing Applications of Mehra], the method being 
performed by an interface comprising an engine [p. 31 , figure in section 3, Context 
Processor of Mehra] for communicating with the front-end systems and a utility layer for 
communicating with the back-end systems, the method comprising the steps of: 

the engine receiving from a front-end system a message incorporating a request 
for a transaction to be performed by a back end system but not indicating a particular 
back-end system suitable for the transaction [p. 32, section 3.2.1 of Mehra], wherein the 
message does not include an operation identifier identifying the transaction to be 
performed [a match is found between the business transaction information and the 
pattern, the content based switching logic 316 outputs a switching decision to a output 
interface 320. The switching decision may, for example, indicate that a match was found 
and identify the processing node or server; col. 9, lines 29 - 35 and col. 3, lines 14 - 23 
of Abjanic; examiner notes the identity of the processing node is determined by the 
switching logic and not the message], 

the engine using a process map [configuration pattern; col, 7, lines 6 - 33 of 
Abjanic] to select one of a plurality of nodes in a node layer which may provide a 
suitable link to the back-end systems for the request [col. 7, lines 23 - 33 of Abjanic], 
the process map being automatically built [configuration patterns may be dynamically 
changed or updated by a user or by a program or application. For example, a program 
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may detect the failure of one or more servers and/or detect the response time of 
servers, and then update the configuration pattern to account for these changes in the 
network; col. 6, lines 50 - 63 of Abjanic] to link message types to nodes according to 
exposed business logic capabilities of the nodes [col. 7, lines 33 - 43 of Abjanic] and 
comprising script messages [XML pattern; col. 7, lines 5-33 of Abjanic], each message 
specifying an associated node [configuration patterns; col. 7, lines 5-33 of Abjanic], a 
list of the parameters the node requires [configuration pattern may require multiple 
patterns, or even a hierarchical arrangement of data elements in the application data for 
a specific match; col. 9, lines 10 - 35 of Abjanic], and values which it returns for a type 
of incoming message [Broker 410 also translates destination addresses for return 
messages or replies from the processing node or server sent to the client; col. 10. lines 
55 - 67 and col. 1 1 , lines 1 - 33 of Abjanic], wherein the engine does not contain any 
business logic [message director 145 to direct or switch messages to a selected server 
based upon the content of application data, such as business transaction information, 
col. 4, lines 50 - 60 of Abjanic; examiner notes that the message director sends 
messages to the server or processing node to process the message, col. 3. lines 10 - 
22 of Abjanic, therefore, the message director does not contain any business logic], 

the engine passing a request to the selected node [p. 32, the interface of the 
Business Controller Object, section 3.3.2 of Mehra], 

the selected node communicating with a utility with which it is associated to 
instruct the utility to perfonn the transaction, receiving a response from the utility, and 
passing the response back to the node [p. 32. sections 3.4.1 and 3.4.2 of Mehra], 
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the node passing the response back to the engine [p. 32, section 3.2.1 "The 
business logic layer... returns an XML output data stream" of Mehra], and the engine 
passing the response back to the requesting front-end [p. 32, section 3.2.1 "The style 
sheet rendering engine merges the XML data stream with the appropriate XSL template 
file to render HTML output to the browser" of Mehra]. 

22. As to claim 21 , this is rejected for the same reasons as claims 1 0 and 1 5 above. 

23. As to claim 23, Mehra teaches the process map is an XML script file [section 
3.1.1. p. 31]. 

24. As to claim 24. this is a product claim that corresponds to method claim 20; note 
the rejection to claim 20 above, which also meets this product claim. 

25. Claim 14 is rejected under 35 U.S.C. 103(a) as being unpatentable over 
Mehra and Abjanic further In view of U.S. Patent No. 6,434,555 to Frolund et al. 
[hereinafter Frolund, cited in previous office action]. 

26. As to claim 14, Mehra as modified does not teach the engine is configured for 
activating a sequence of nodes for a transaction, and each node is configured for 
performing a rollback if a transaction fails. 
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However, Frolund teaches the engine is configured for activating a sequence of 
nodes for a transaction, and each node is configured for performing a rollback if a 
transaction fails [col. 4, lines 21 - 52 of Frolund]. 

It would have been obvious to a person of ordinary skill in the art at the time the 
invention was made to combine Mehra, Abjanic and Frolund because this provides 
outcome determination so that the result of a transaction can be used to make a 
decision [col. 2, lines 28 - 39 of Frolund]. 

Conclusion 

27. THIS ACTION IS MADE FINAL. Applicant is reminded of the extension of time 
policy as set forth in 37 CFR 1 . 1 36(a). 

A shortened statutory period for reply to this final action is set to expire THREE 
MONTHS from the mailing date of this action. In the event a first reply is filed within 
TWO MONTHS of the mailing date of this final action and the advisory action is not 
mailed until after the end of the THREE-MONTH shortened statutory period, then the 
shortened statutory period will expire on the date the advisory action is mailed, and any 
extension fee pursuant to 37 CFR 1 .1 36(a) will be calculated from the mailing date of 
the advisory action. In no event, however, will the statutory period for reply expire later 
than SIX MONTHS from the mailing date of this final action. 
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28. Any inquiry concerning this communication or earlier communications from tlie 
examiner sliould be directed to Li B. Zlien whose telephone number is (571 ) 272-3768. 
The examiner can normally be reached on Mon - Fri, 8:30am - 5pm. 

If attempts to reach the examiner by telephone are unsuccessful, the examiner's 
supervisor, William Thomson can be reached on 571-272-3718. The fax phone number 
for the organization where this application or proceeding is assigned is 571-273-8300. 

Information regarding the status of an application may be obtained from the 
Patent Application Information Retrieval (PAIR) system. Status information for 
published applications may be obtained from either Private PAIR or Public PAIR. 
Status infomnation for unpublished applications is available through Private PAIR only. 
For more information about the PAIR system, see http://pair-direct.uspto.gov. Should 
you have questions on access to the Private PAIR system, contact the Electronic 
Business Center (EBC) at 866-217-9197 (toll-free). 
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